博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Handlebars.js,Json+ajax+拼html
阅读量:6554 次
发布时间:2019-06-24

本文共 10645 字,大约阅读时间需要 35 分钟。

英文版:

,

 
html标签
中  {
{  和  }}  之间为handlerbars的变量;

{
{title}}

{
{body}}
把数据放到自己定义的 
<script> 标签中;

编译模版

使用 
Handlebars.compile() 进行编译模版;
var source   =$("#entry-template").html();
var template = Handlebars.compile(source);
智能编译模版(在移动端也能运行哦么么哒)

生成html代码

通过上面的模版和数据混合编译后的结果:
var context = {title: "标题", body: "我是字符串!"}var html    = template(context);

{
{title}}

{
{body}}
var template = Handlebars.compile(source);    var context = {title: "标题", body: "我是字符串!"} //数据信息    var html    =template(context);    document.getElementById("div1").innerHTML= html;
//jQuery中 html(),插入到div1
 
---------------------------------------------
//模版的代码和JS的代码如防止HTML被转义的方法;
{
{ }}和 {
{
{}}}和区别就是, 如果你不希望变量里面的字符串被转义就使用{
{
{ }}}对变量进行处理;//可能以因为body等是html标签,避免将变量误认为特殊关键字,需要{
{
{ }}}
Handlebars的 
{
{expression}}
 表达式会返回一个 HTML编码 
HTML-escape 过的值。如果
不希望Handlebars来编码这些值,使用三个大括号即可:
{
{
{

{
{title}}

{
{
{body}}}
数据如下:
{  title: "All about 

Tags", body: "

This is a post about <p> tags

"}
Handlebars 不会再对 
Handlebars.SafeString 安全字符串进行编码。如果你写的 helper 用来生成 HTML,就经常需要返回一个 
new Handlebars.SafeString(result)。在这种情况下,你就需要手动的来编码参数了。
定义的Helper如下:
Handlebars.registerHelper('link', function(text, url) {      text = Handlebars.Utils.escapeExpression(text);      url  = Handlebars.Utils.escapeExpression(url);       var result =''+ text +'';  //手动编码是指这句?  return new Handlebars.SafeString(result);    });
这样来编码传递进来的参数,并把返回的值标记为 安全,这样的话,即便不是哟给你“三个大括号”,Handlebars 就不会再次编码它了。
渲染以后的结果如下:
&lt; < , little to
&gt; >, greater to

All About <p> Tags

This is a post about <p> tags

//代码如下:
-------------------------------------------------------------
Handlerbars的自定义表达式

块级表达式:#开头,/结尾。
块级表达式允许你定义一个helpers,并使用一个不同于当前的上下文(context)来调用你模板的一部分。现在考虑下这种情况,你需要一个helper来生成一段 HTML 列表:

{
{
#list people}} {
{firstName}} {
{lastName}}{
{
/list}}
并使用下面的上下文(数据):
{  people: [    {firstName: "Yehuda", lastName: "Katz"},    {firstName: "Carl", lastName: "Lerche"},    {firstName: "Alan", lastName: "Johnson"}  ]}
此时需要创建一个 名为 
list 的 helper 来生成这段 HTML 列表。这个 helper 使用
people 作为第一个参数,还有一个 
options 对象(hash哈希)作为第二个参数。这个 options 对象有一个叫 
fn 的属性,你可以传递一个上下文给它(fn),就跟执行一个普通的 Handlebars 模板一样:
在JS里面定义这个helper;
Handlebars.registerHelper('list', function(items, options) {  var out ="
    "; for(var i=0, l=items.length; i
    "+ options.fn(items[i]) +" " ; /*options.fn相当于一个编译的函数*/ } return out +"
";});
执行以后的结果是:
  • Yehuda Katz
  • Carl Lerche
  • Alan Johnson
自定义块表达式还有很多别的特性, 比如可以直接使用 IF 和 ELSE;
//代码如下:
people
对应数据中的people[] }} {
{
#list people}} {
{firstName}} {
{lastName}} {
{
/list}}

块级的 helpers 还有很多其他的特性,比如可以创建一个 else 区块(例如,内置的 if helper 就是用 else)。
注意,因为在你执行 options.fn(context) 的时候,这个 helper 已经把内容编码一次了,所以 Handlebars 不会再对这个 helper 输出的值进行编码了。如果编码了,这些内容就会被编码两 次!

Handlebars次级数据的渲染(Handlebars 路径)

Handlebars支持简单的下级对象获取和上级对象获取, 跟 Mustache一样样的.

{

{name}}

Handlebars 同样也支持嵌套的路径,这样的话就可以
在当前的上下文中查找内部嵌套的属性了。

{
{title}}

By {
{author.name}}

{
{body}}
上面的模板使用下面这段上下文:
这样一来 Handlebars 就可以直接把JSON数据拿来用了。
var context = {  title: "My First Blog Post!", author: {
id: 47, name:"Yehuda Katz"}, body: "My first post. Wheeeee!"};
-------------------------
Handlebars 可以迭代Object对象(纯对象或者数组); 在模版中的
../是对象的父级
;

Comments

{
{
#each comments}}

{
{title}}

{
{body}}< div>{
{/each}}
尽管 a 链接在输出时是以 comment 评论为上下文的,但它仍然可以退回上一层的上下文(post上下文)并取出permalink(固定链接)值。
var context = {  post: {    body:'这是文章内容',    permalink: 'http://xx.com/xx',    comments:[{      title:'这篇文章不错,赞一个'    },{      title:'好文要顶!'    }]  }}
../ 标识符表示对模板的父级作用域的引用,并不表示在上下文数据中的上一层。这是因为块级 helpers 可以以任何上下文来调用一个块级表达式,所以这个【上一层】的概念用来指模板作用域的父级更有意义些。
The exact value that 
../ will resolve to varies based on the helper that is calling the block. Using 
../ is only necessary when context changes, so children of helpers such as 
each would require the use of 
../while children of helpers such as 
if do not.
{
{permalink}}{
{#each comments}} {
{../permalink}} {
{#if title}} {
{../permalink}} {
{/if}}{
{/each}}
In this example all of the above reference the same permalink value even though they are located within different blocks. This behavior is new as of Handlebars 4, the  discuss the prior behavior as well as the migration plan.
Handlebars也允许通过一个 this 的引用来解决 helpers 和 数据字段间的名字冲突
 
下面展示的name都是同样的东西;

{

{./name}} or {
{this/name}} or {
{this.name}}

上面的这一种方式都会将 name 字段引用到当前上下文上,而不是 helper 上的同名属性。

-----------------------------------------------------

注释: {
{!-- --}}
 或者{
{! }}
或者 <!-- -->.

可以把模版专用的注释写在模版文件里面么么哒. 提高代码的可读性, 这个也算是最佳实践吧;
{
{!-- only output this author names if an author exists --}}{
{#if author}}

{
{firstName}}{
{lastName}}

{
{/if}}
{
{!-- --}}和{
{! }}的注释不会出现在生成的代码中; 如果使用 <!-- --> 注释的代码会出现在生成的代码中;

------------------------------------------------------

自定义标签(Helpers)

Handlebars 的 helpers 在模板中可以访问任何的上下文。可以通过
Handlebars.registerHelper 方法注册一个 helper。

By {
{fullName author}}

{
{body}}

Comments

{
{#each comments}}< h2>By {
{fullName author}}
{
{body}}
{
{/each}}
用下面的上下文数据和 helpers:
var context = {  author: {firstName: "Alan", lastName: "Johnson"},  body: "I Love Handlebars",  comments: [{    author: {firstName: "Yehuda", lastName: "Katz"},    body: "Me too!"  }]};//就是下面这个helper提供了模版中的自定义标签;Handlebars.registerHelper('fullName', function(person) {  return person.firstName +""+ person.lastName;});
生成的结果如下:

By Alan Johnson

I Love Handlebars

Comments

By Yehuda Katz

Me Too!
代码如下:
-----------------------------------------
Helpers 会把当前的上下文作为函数中的 this 上下文。
在自定义标签的Helper可以使用this, this是当前的对象;
    {
    {#each items}}
  • {
    {agree_button}}
  • {
    {/each}}
这个是填充的数据和定义的Helpers:(使用下面的 this上下文 和 helpers)
var context = {  items: [    {name: "Handlebars", emotion: "love"},    {name: "Mustache", emotion: "enjoy"},    {name: "Ember", emotion: "want to learn"}  ]};Handlebars.registerHelper('agree_button', function() {  var emotion = Handlebars.escapeExpression(this.emotion),      name = Handlebars.escapeExpression(this.name);  return new Handlebars.SafeString(    ""  );});
生成的结果如下:
如果你希望你返回的HTML代码不被转义, 就要在定义的Helper中返回 new Handlebars.SafeString; 
return new Handlebars.SafeString(代码)

自定义标签(Helpers)的更多信息;

Handlebars 提供 
if 在模版中进行简单的逻辑处理; 以及迭代处理的标签 
each .
//例子代码段:
//handlebars的IF ELSE语句和 each语句的例子:

内置的 Helpers

1.each helper

你可以使用内置的 each helper 来循环一个列表,循环中可以使用this 来代表当前被循环的列表项。

    {
    {
    #each people}}
  • {
    {
    this}}
  • {
    {
    /each}}

使用这个上下文:

{  people: [    "Yehuda Katz",    "Alan Johnson",    "Charles Jolley"  ]}

会得到:

  • Yehuda Katz
  • Alan Johnson
  • Charles Jolley
  • 事实上,可以使用 this 表达式在任何上下文中表示对当前的上下文的引用。
    还可以选择性的使用 else ,当被循环的是一个空列表的时候会显示其中的内容。

    {
    {#each paragraphs}}

    {

    {this}}

    {
    {else}}

    No content

    {
    {/each}}

    在使用 each 来循环列表的时候,可以使用 {
    {
    @index}} 来表示当前循环的索引值

    {
    {#each array}} {
    {@index}}: {
    {this}}{
    {/each}}

    对于 object 类型的循环,可以使用 {
    {@key}}
     来表示:

    {
    {
    #each object}} {
    {
    @key}}: {
    {
    this}}{
    {/each}}

     

    --------------------------------------

    2. with helper

    一般情况下,Handlebars 模板在计算值时,会把传递给模板的参数作为上下文。

    var source   = "

    {

    {lastName}}, {
    {firstName}}

    ";var template = Handlebars.compile(source);template({firstName: "Alan", lastName: "Johnson"});

    结果如下:

    Johnson, Alan

    不过也可以在模板的某个区域切换上下文,使用内置的 
    with helper即可。

    {
    {title}}

    {
    {#with author}}

    By {
    {firstName}} {
    {lastName}}

    {
    {/with}}

    在使用下面数据作为上下文时:

    {  title:"My first post!",  author: {    firstName: "Charles",    lastName: "Jolley"}}

    会得到如下结果:

    My first post!

    By Charles Jolley

    ----------------------------

    3. if helper

    if 表达式可以选择性的渲染一些区块。如果它的参数返回 false,undefinednull"" 或 [](译注:还有 0)(都是JS中的“假”值),Handlebars 就不会渲染这一块内容:

    {
    {#if author}}

    {
    {firstName}} {
    {lastName}}

    {
    {/if}}

    当时用一个空对象({})作为上下文时,会得到:

    在使用 
    if 表达式的时候,可以配合 
    {
    {else}}
     来使用,这样当参数返回 假 值时,可以渲染 else 区块:
    {
    {
    #if author}}

    {
    {firstName}} {
    {lastName}}

    {
    {
    else}}

    Unknown Author

    {
    {
    /if}}
    4.  

    unless helper

    unless helper 和 if helper 是正好相反的,当表达式返回假值时就会渲染其内容:

     

    {
    {#unless license}}

    WARNING: This entry does not have a license!

    {
    {/unless}}
    如果在当前上下文中查找 license 返回假值,Handlebars 就会渲染这段警告信息。反之,就什么也不输出。

    5.log helper

    log helper 可以在执行模板的时候输出当前上下文的状态。

    {
    {log"Look at me!"}}
    这样会把委托信息发送给 Handlebars.logger.log,而且这个函数可以重写来实现自定义的log。

     

    Literals

    Helper calls may also have literal values passed to them either as parameter arguments or hash arguments. Supported literals include numbers, strings, 
    true
    false
    null and 
    undefined.
    {
    {agree_button "My Text"class="my-class" visible=true counter=4}}

    Partials

    Handlebars partials allow for code reuse by creating shared templates. Rendering this template
    {
    {> userMessage tagName="h1" }}

    Comments

    {
    {#each comments}}{
    {> userMessage tagName="h2" }}{
    {/each}}
    when using this partial and context:
    Handlebars.registerPartial('userMessage',    '<{
    {tagName}}>By {
    {author.firstName}} {
    {author.lastName}}
    '+'
    {
    {body}}
    ');
    var context = {  author: {firstName: "Alan", lastName: "Johnson"},  body: "I Love Handlebars",  comments: [{    author: {firstName: "Yehuda", lastName: "Katz"},    body: "Me too!"  }]};
    results in:

    By Alan Johnson

    I Love Handlebars

    Comments

    By Yehuda Katz

    Me Too!

    Built-In Helpers

    Handlebars offers a variety of built-in helpers such as the 
    if conditional and 
    each iterator.
     

    API Reference

    Handlebars offers a variety of APIs and utility methods for applications and helpers.

    转载于:https://www.cnblogs.com/zyjzz/p/6561839.html

    你可能感兴趣的文章
    Linux 用户和用户组管理
    查看>>
    tomcat架构分析(valve源码导读)
    查看>>
    spring中InitializingBean接口使用理解(转)
    查看>>
    基于php5.5使用PHPMailer-5.2发送邮件
    查看>>
    InstallShield 2012 Spring新功能试用(16): Suite/Advanced UI 或 Advanced UI安装程序能在安装时进行输入合法性校验与反馈...
    查看>>
    C#面试宝典
    查看>>
    基金项目的英文
    查看>>
    《软件性能测试与LoadRunner实战教程》喜马拉雅有声图书上线
    查看>>
    ios 字典转模型
    查看>>
    Java类集
    查看>>
    类的生命周期
    查看>>
    php apache用户写文件夹权限设置
    查看>>
    003-诠释 Java 工程师【一】
    查看>>
    浅析rune数据类型
    查看>>
    普通用户开启AUTOTRACE 功能
    查看>>
    Bind+Nginx实现负载均衡
    查看>>
    游侠原创:推荐一款免费的Syslog转发工具
    查看>>
    UIKeyboard键盘相关知识点-IOS开发
    查看>>
    你真的会 snapshot 吗? - 每天5分钟玩转 OpenStack(163)
    查看>>
    onAttachedToWindow和onDetachedFromWindow调用时机源码解析
    查看>>